home *** CD-ROM | disk | FTP | other *** search
/ Eagles Nest BBS 4 / Eagles_Nest_Mac_Collection_Disc_4.TOAST / Database Management / FoxPro25#1 / FoxPro 2.5 Disk - 1 Setup.image / Cpzero.prg / Cpzero.bin
Text File  |  1993-12-04  |  3KB  |  155 lines

  1. * CPZERO -- Poke a codepage byte into a database header
  2. * Author: Walter Kennamer
  3. * Copyright Microsoft Corp, 1993
  4. *
  5. * Usage: 
  6. *    DO CPZERO WITH dbfname                     && marks the database with codepage 0 (i.e., no codepage)
  7. *    DO CPZERO WITH dbfname, codepage_number    && marks the database with specified codepage
  8. *
  9. * Some common valid numbers are:
  10. *   Windows            1252
  11. *   DOS                 437
  12. *   International DOS   850
  13. *
  14.  
  15. PARAMETER m.fname, m.cpbyte
  16. IF SET("TALK") = "ON"
  17.    SET TALK OFF
  18.    m.mtalk = "ON"
  19. ELSE
  20.    m.mtalk = "OFF"
  21. ENDIF   
  22.  
  23. #define C_TOTAL 20     && total code page numbers suppoted
  24.  
  25. IF PARAMETERS() < 2
  26.    m.cpbyte = 0
  27. ENDIF   
  28.  
  29. PRIVATE m.mtalk, m.vuename
  30.  
  31. #define c_buf_size 8096
  32.  
  33. #define c_noopen   1
  34. #define c_badbyte  2
  35. #define c_maxerror 3
  36.  
  37. m.vuename = ""
  38.  
  39. DECLARE error_array[c_maxerror]
  40. error_array[c_noopen] = "The database could not be opened"
  41. error_array[c_badbyte] = "Invalid code page specified."
  42.  
  43. DO setup
  44. DO main
  45. DO cleanup
  46.  
  47. PROCEDURE setup
  48. m.vuename = SYS(2023)+"\"+SYS(3)+".VUE"
  49. CREATE VIEW (m.vuename)
  50.  
  51.  
  52. PROCEDURE cleanup
  53. IF FILE(m.vuename)
  54.    SET VIEW TO (m.vuename)
  55.    DELETE FILE (m.vuename)
  56. ENDIF   
  57. SET TALK &mtalk
  58.  
  59. PROCEDURE main
  60. PRIVATE m.fp_in, m.buf, m.found_one, m.i, m.outbyte
  61.  
  62. * Set up table of code pages and DBF bytes numbers
  63. DIMENSION cpnums[C_TOTAL,2] 
  64. cpnums[ 1,1] = 437
  65. cpnums[ 1,2] = 1
  66. cpnums[ 2,1] = 850
  67. cpnums[ 2,2] = 2
  68. cpnums[ 3,1] = 1252
  69. cpnums[ 3,2] = 3
  70. cpnums[ 4,1] = 10000
  71. cpnums[ 4,2] = 4
  72. cpnums[ 5,1] = 852
  73. cpnums[ 5,2] = 100
  74. cpnums[ 6,1] = 866
  75. cpnums[ 6,2] = 101
  76. cpnums[ 7,1] = 865
  77. cpnums[ 7,2] = 102
  78. cpnums[ 8,1] = 861
  79. cpnums[ 8,2] = 103
  80. cpnums[ 9,1] = 895
  81. cpnums[ 9,2] = 104
  82. cpnums[10,1] = 620
  83. cpnums[10,2] = 105
  84. cpnums[11,1] = 737
  85. cpnums[11,2] = 106
  86. cpnums[12,1] = 857
  87. cpnums[12,2] = 107
  88. cpnums[13,1] = 10007
  89. cpnums[13,2] = 150
  90. cpnums[14,1] = 10029
  91. cpnums[14,2] = 151
  92. cpnums[15,1] = 10006
  93. cpnums[15,2] = 152
  94. cpnums[16,1] = 1250
  95. cpnums[16,2] = 200
  96. cpnums[17,1] = 1251
  97. cpnums[17,2] = 201
  98. cpnums[18,1] = 1253
  99. cpnums[18,2] = 202
  100. cpnums[19,1] = 1254
  101. cpnums[19,2] = 203
  102. cpnums[20,1] = 0
  103. cpnums[20,2] = 0
  104.  
  105. IF EMPTY(m.fname)
  106.    m.fname = getfile("DBF|SCX|FRX|LBX|MNX","DBF name")
  107. ENDIF
  108. IF !EMPTY(m.fname)
  109.    CLOSE DATABASES
  110.    m.outbyte = m.cpbyte
  111.    m.found_one = .F.
  112.    FOR m.i = 1 TO C_TOTAL
  113.       IF m.cpbyte = cpnums[m.i,1]
  114.          m.outbyte = cpnums[m.i,2]
  115.          m.found_one = .T.
  116.          EXIT
  117.       ENDIF
  118.    ENDFOR
  119.    IF m.found_one
  120.       m.cpbyte = m.outbyte
  121.    ELSE
  122.       * Was it a valid DBF byte if it wasn't a valid code page?
  123.       FOR m.i = 1 TO C_TOTAL
  124.          IF m.cpbyte = cpnums[m.i,2]
  125.             m.found_one = .T.
  126.          ENDIF
  127.       ENDFOR
  128.       IF !m.found_one
  129.          DO errormsg WITH c_badbyte
  130.          RETURN TO poke
  131.       ENDIF
  132.    ENDIF
  133.    
  134.    IF FILE(m.fname)
  135.        m.fp_in = fopen(m.fname,2)
  136.        IF m.fp_in > 0
  137.           =fseek(m.fp_in,29)
  138.           =fwrite(m.fp_in,CHR(m.cpbyte))   && poke codepage number into byte 29
  139.           =fclose(m.fp_in)
  140.        ELSE
  141.           DO errormsg WITH c_noopen
  142.           RETURN TO poke
  143.        ENDIF
  144.     ELSE
  145.        DO errormsg WITH c_noopen
  146.        RETURN TO poke
  147.     ENDIF
  148. ENDIF      
  149.  
  150.  
  151. PROCEDURE errormsg
  152. PARAMETER num
  153. WAIT WINDOW error_array[num] NOWAIT
  154.